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(57) Abstract: A method and system for billing 
application software usage transactions conducted over 
the Internet between a User on a terminal (101) and 
an Applications Service Provider (ASP) (104) server 
system through an Internet Access Provider (IAP) (102). 
Upon connection between the User's terminal (101) and 
the ASP, the ASP system checks the User's terminal for 
the User's identity and his "usage status". This "usage 
status" identifies for each software package offered by 
the ASP, whether the User is a "free of charge** software 
evaluator, or a paying customer. This "usage status" 
together with the User's billing information such as 
his credit card or other financial contract between the 
User's company and the ASP is stored in a transaction 
server for the duration of his connection session. When 
the User selects a particular application software from 
a library of various application software offered by . 
the ASP, an Application Server (108) transmits to the 
User's terminal entry form images for the User to enter 
his input information data needed to use the selected 
application software. A Pricing Module predetermines 
the usage price, of application software "Runs", on the 
basis of the data in the input form images submitted back 
by the User to the ASP system. A Billing Server (110) 
associates the price signal from the Pricing Module with 
the User's "usage status" record from the transaction 
server database and determines an actual price for the usage. At the end of each application "Run", the User's account is debited 
by either a credit card clearing system (112) or by the User's predetermined financial arrangement, which is stored in the financial 
database (1 1 1) of the billing server. At the end of Ihe User's session, the charges for all the transactions during the session are 
stored in the financial database (11 1) of the billing server. 
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A System For Billing Of Software Usage Service Over The Internet 
RELATED APPLICATION 

This application is related to U.S. Application No. 60/180,275 filed February 4, 2000, 
which is incorporated herein by reference. 

TECHNICAL FIELD 

This invention relates to a method and system for billing software usage services 
transacted for and provided over a data network such as the Internet or an Intranet. 

BACKGROUND OF THE INVENTION 

The Internet today has become the gateway for connected Users to access a plethora 
of information and interactive services. In addition, the Internet can provide Users a 
mechanism for utilizing application software that are located on servers in various locations 
and are connected via the Internet network. The availability of the use of application software 
on a network is provided by various businesses known generally in the industry as 
Applications Service Providers (ASP). Through the ASP services, software can be made 
available for use on a rental basis whereby the User is charged by various methods: fixed 
charges, monthly charges, "connect time" charges and others. 

The use of application software normally involves several steps whereby, 

• The User feeds data into specific software entry forms, 

• The application software "Runs" the User's input through its internal execution processes 
that consist of various complex algorithms that are linked to internal or external data 
sources, 

• Output forms are created that present the results of the software execution process to the 
User. 
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These output forms contain information m the form of graphs, charts, numbers and 
text. The User examines the resultant output forms and may elect to continue "running" the 
software by changing some of his data input and submitting it for another "run" cycle, or may 
terminate his current running session of the particular software. The information contained in 
the output forms created by the software is valuable to the User, and therefore such software 
usage establishes a basis for a business transaction whereby the User is charged for the 
receipt of the results in the output forms. 

Billing for software usage requires the I iser to establish a financial relationship with 
the Applications Service Provider (ASP). However the relationship may be very fleeting if 
the User wants to use the software provided by the ASP only on an irregular, occasional 
basis. Furthermore, perhaps due to geographical distance, the ASP might not wish to enter 
into a financial arrangement with the User. In that case, the User needs to be charged for the 
usage only while connected to the ASP service However, even if User has an established 
financial arrangement with the ASP, the User and/or the ASP service provider, may desire to 
have the software usage charges tied to and determined during the connection session. 

The existing billing arrangements for fixed charges, monthly charges, and "connect 
time" charges are inadequate and lacking. Fixed charges require a financial contract with the 
User, which may be impractical especially for an occasional User of the ASP service. 
Secondly, billing by logging the time the User is connected to the ASP service does not 
reflect the value of the transaction and is very erratic. There is a need to tie the billing to the 
usage of specific software during the connection session between the User and the ASP. 
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• perform various internal calculations and returns the calculation 
ut forms. Such application software enables many options to 
nons depending on the User's input. In one sample of the User's 
t ormed by the software may be very complex and require the 
mal schemes and algorithms of the software. In a variation of some 
-quired calculations are simple and utilize only a fraction of the 
>es. The User normally uses such software by making a series of 
v. h he changes some of his input to cause the software to perform 
nes that generates different results. Each such different "Runs" may 
rate depending on the run. 

lore agreeing to be charged for usage of specific application 

^ to test and evaluate the software. The ASP may avail the software 

tor testing and evaluation at no charge for a limited time period. 
\1 test period the User "usage status'* is as an "Evaluator" and the 
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The object ot . invention is to provide a system and method for billing for software 
usage services over a i ■• ■ work during a connection session between the User's terminal and 
ASP's service systcrr te system will be able to track the charging status of the Users as 
they move from eva 1 1 = ig software free of charge, to become paying customers. For the 
paying customers, thr >,tem will provide a method of billing per transaction for each 
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specific application by calculating the charges on the basis of the User's input to, and 
from, the specific application software utilized during the session. 

The present invention provides a system and method for determining the chart 
the billing for software usage transactions conducted over the Internet between Users 
connected through an Internet Access Provider (IAP) to an Applications Service Provi. 
(ASP) service system. In accordance with the invention, upon the connection of a Use: 
ASP, the system checks the User's terminal storage disk for the User's identity and 
determines the User's terminal "Billing Policy" i.e. the specific details of the specific ; 
and charge items that were assigned to the specific user to debit his charge account. I r 
User's terminal "usage status" is transmitted to the system's billing platform together w 
the User's temporary Internet Protocol (IP) that is assigned through by the IAP to the I 
session for use by the User's terminal. The billing platform intercepts the User's input .!. 
stream of the specific software that the User desires to use, and calculates the charge 
associated with this data stream. The calculated charge is referenced with the User's ' n 
status" and his "Billing Policy" to set the actual price for the "processing" of the User 
data by the specific software system. This actual charge is stored in the system and is 
accumulated each time the User varies the input data. This process can repeat itself for \ 
utilization of different software available for use on the ASPs service during the User s 
temporary Internet session. The billing system debits an account of the User established 
the transaction. This account will likely be established by the User prior to the executn" 
the transaction for billing in a predetermined manner to, for example, a User's contract 
the ASP, a User's selected credit card, a User's telephone account associated with a phi-* 
number, or other billing mechanism. For example, in connection with the User 

telephone account, an Automatic Number Identification (ANI) can be associated with ih 
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User's terminal, and a telephone account associated ^ nc ANI is billed for the cost of the 
transaction. 

BRIEF DESCRIPTION OF THE DRAWING 

Fig. 1 is a block diagram showing the network r iients of the invention. 
DESCRIPTION OF A PREFERRED EMBODIMEN I > i THE INVENTION 

Fig. 1 is a block diagram showing the network < ments for providing the billing 
functionality of the present invention for software usa^i unsactions conducted by a User 
through an Internet Access Provider to an Application .Vr v ice Providers (ASP) connected to 
the Internet. 

With reference to Fig. 1 a User's terminal 101 connected to the Internet 103 
through an Internet Service Provider (ISP) 102. By inpuu mg the URL address of the ASP the 
User may be linked to the ASP web site HTML pages a liernately, the User may be linked 
directly to the ASP 104 by clicking an icon on the User < desktop. The "User" may be a 
casual web visitor browsing the Internet or a regular cum; »mer who is linking to the ASP for 
the purpose of using software offered by the ASP. The web site HTML pages contain 
various icons representing different software that are otic red for use on the ASP software 
service system. Alternatively, the listing of available si»ti ware application can be provided to 
the User through an XML front end. 

In many cases the ASP service is offered through an Internet portal that are accessed by 
casual visitors who browse the Internet. These casual vim tors may desire to test and evaluate 
the software that are presented on the web portal and arc offered for usage through 
connection with the ASP service system. The ASP mav of fer software testing and evaluation 
free of charge for a limited time period or for a limited number of "Runs". The ASP desires 
to have a system that checks the history of usage by a pur licular User in order to determine 
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when to start charging him for his usage of particular software. When the User's free of 
charge privileges terminate, the User may wish to pay for usage just during his usage session 
without establishing any financial contractual arrangements. In that case, the User's credit 
card may be used as an instrument of payments. The User may wish to run different software 
during his visit to the portal. In that case the User's total charges will be accumulated for the 
succession of "Runs" for each application. 

The present invention provides a system and method for billing for software usage 
services under different types of charging methods. The system will be able to track the 
charging status of the Users as they move from evaluating software free of charge, to become 
paying customers. For the paying customers who use software regularly, the billing may be 
based on fixed charges with a pre-arranged Financial contract. The non-regular User can 
submit his credit card for on line debiting. The User may also be part of company employees 
who use the software under various company policies. For all Users however, the system will 
provide a method of billing per transaction for each specific application by calculating the 
charges on the basis of the User's input to, and output from, the specific application software 
utilized during the session. 

A connection between the User's terminal 101 and the ASP software usage service 
system 104 is initiated by, for example, the User clicking on any icon that represents a 
specific software available for Usage. Upon such initiation, the ASP control server 105 
checks first, on the User's terminal storage disk, for a certain file which determine the User s 
identity and his "Usage Status". If the control server 105 finds no such file, the control server 
105 determines the User to be a new, first-time User, and transfers to the User's computer 
storage disk a "client" usage file that initiates the user's identity and usage status to enable 
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him to connect to the ASP service system. The control server 105 then establishes a 
connection between the User's terrr inal and the ASP service system 104. 

Upon checking for the "usage status" on the User's terminal storage disk and 
establishing the connection with the User's terminal, the ASP control server 105 transfer c 
User's identity to the billing server 1 10 that checks the financial database 1 1 1 for a finur - 
arrangements record that is associated with the User's identity. A financial record code <• . 
back to the control server 105, which in turn-passes to the transaction server 106 all of th» 
User's information. The transaction server 106 creates a record of the User's identity thm 
contains his billing and software usage status and the User's temporary Internet Protocol • ■ i 
that is assigned to the User's terminal for the User's session by an Internet Access Provide 
(IAP). The transaction server 106 stores this record for the current connection session in r 
Usage Status Database 107. 

The ASP control server 105 receives the User's record signal from the Transaction 
server 106 that is stored in the Usage status database 107. The ASP control server 105 cu<-. ^ s 
this record to determine whether to send to the User's terminal 101 an image.of entry for 
for the User to enter his credit card information prior to initiating connection with the Use- - 
terminal. When the credit card entry form is sent to the User's terminal 101 and received 
back by the ASP control server 105, it is then transmitted to the Billing server 1 10. The 
Billing server 1 10 checks the validity of the credit card information by engaging the credi *' 
card debit system 1 12. The approved credit card data record is stored in the financial dat jKinc 
11 1 or is transmitted back to User's terminal for additional information or as a message Uk-.i 
the credit card is not valid. 

The ASP control server 105 sends a signal to the Application Server 108 to establ ■ ^ 
connection with the User's terminal 101 and to initiate the running/execution of the selecit d 
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application software from the application library 1 13. The application server 108 transmits to 
the User's terminal 101, the images of the entry forms of the particular software selected by 
the User so he may enter his input information data needed to run the application software, 
and halts the running/execution process. Upon receiving from the User's terminal 101 the 
images of the filled-out data entry of the software's input forms, the image forms are 
transmitted to the ASP application server 108 together with a User identity signal. The 
application server 108 decides, on the basis of the signal received, whether to send the filled- 
up User's forms to the application software for the resumption of the execution process or 
transmit these images to the Pricing Module 109. 

When receiving the filled-up data input images, the Pricing Module 109 examines the 
entry data and calculates a price of this specific usage request by associating the data in the 
input form with the record of usage prices components stored in usage prices database 1 14. 
This calculated price from the pricing server 109 together with the User's "usage status" 
record from the transaction server database 107 are transmitted to the Billing Server 1 10 
which determines an actual charge for this specific usage by utilizing the financial record in 
database 1 1 1. The information of the actual price charges that will be incurred by the User for 
his requested software "Run" is transmitted to the User's terminal 101 for approval. Upon 
receiving the User's approval signal of the actual charges, Application Server 108 signals the 
application software to resume its running/execution of the filled-up input forms. 

Upon completion/termination of the running/execution, the application server 108 
examines the execution messages in the output from the run/execution to determine whether a 
successful execution by the the application software took place. A signal for a successful 
execution is transmitted to the Billing server 1 10 to initiate the debiting of the User's account 
by either a credit card clearing system 1 12 or by the User's purchase order which may be 

-8- 



WO 01/61592 PCT/US01/03361 

stored in the financial database 1 1 1 of the Billing server 1 10. The Billing server 1 10 then 
creates a record of this debit and stores it in the financial database 111. The application server 
108 transmits to the User's terminal screen the output images that were created by the 
application software together with a message on the success or failure of his specific run. The 
User can signal, by clicking, for example, an icon on his message screen, that he wishes to 
continue the running/executing of the specific software usage process or terminate its usage. 
If the User signal is that he desires to continue the running/executing, it will cause the 
application server 108 to transmit to the User's terminal his filled-up entry form for 
modification and submittal of another run. If the User signals a termination request, this 
signal is stored by the transaction server 106 in the User's record and the ASP control server 
105 signals to the web server (Not Shown) to transmit to the User's terminal 101 the HTML 
page that displays the portal's software offering. The User may desire to run another software 
by clicking the appropriate icon. The User's temporary Internet Protocol (IP) is transmitted to 
the transaction server 106, which matches the User's IP with the User's usage record (which 
is kept active as long as the User remains linked to the portal) and signals to the Application 
Server 108 to initiate a new software run. 

When the User leaves the portal it signals the end of the User's session. The 
transaction server 106 deletes the User's record, and the charges for all the transactions 
during the session that are associated with the User's identity are stored in the financial 
database 1 1 1 of the billing server. 

While a preferred embodiment of the invention has been described above, those 
skilled in the art will recognize that the invention is applicable to various applications. For 
example, the ASP service system provider could be the IT department within a company, and 
the ASP users are employees within a company. Furthermore, the transaction need not be 
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limited to a software program, but could involve the presentation of information to the user or 
an interactive service. 
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Claims 

1. A method of billing an account associated with a User's identity for the cost of a 
software usage transaction conducted on a network between an Applications Service Provider 
(ASP) service system and a User's terminal, the User's terminal being assigned a temporary 
address on the network that is used for the transaction, said billing and said transaction both 
being conducted on said network, the method comprising: 

transmitting to a User's terminal a list of application software available for use on the 
network; 

receiving a signal from the User's terminal identifying a selected software from a list 
of application software; 

establishing a connection between the User's terminal and the ASPs service system; 

transmitting to the User's terminal a performance signal that checks the User's 
terminal "usage status" condition; 

transmitting to the User's terminal an input form enabling the User to enter input 
information to use the selected application software; , , 

receiving from the User's terminal the input form containing the input information 
entered by the User; 

determining a price of usage associated with the input information and a 
predetermined billing policy; and 

billing an account associated with the User's identity in accordance with the 
determined price upon a successful run of the application software. 

2. The method of claim 1, further comprising: 

transmitting to the User's terminal, computer files enabling execution capability; 
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receiving an identifying signal that associates the User's identity and an assigned 
temporary address; 

storing an association between the User's identity. User's assigned temporary address, 
a User's "usage status" code and the User's selected software; and 

establishing a connection between the User's terminal and an application server. 

3. The method of claim 2, further comprising: 

referencing the price of the usage associated with the input information with the 
User's identity, the User's "usage status" condition and the selected software, to determine 
the actual cost for the transaction and a billing signal; 

referencing the actual cost of the transaction in the billing signal to the account 
associated with the User's identity. 

4. The method of claim 1, wherein the network is one of a data network, the Internet, 
and an Intranet. 

5. The method of claim 4, wherein the assigned temporary addresses is an Internet 
Protocol (IP) address. 

6. The method of claim 4, wherein the ASP's service system provider is the IT 
department within a company. 

7. The method of claim 4, wherein the ASP' s users are the employees within a 
company. 
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8. The method ut urn 4, wherein the ASP's service system provider is an Internet 
Service Provider (ISP) ant c transaction involves providing the User with information. 

9. The method oi urn 5, wherein the ASP's service system provider is an Internet 
Service Provider (ISP), un.! the transaction involves providing the User with an interactive 
service. 

10. The method <»> uiim 6, wherein the list of application software available for use 
on network is transmitted r the User's terminal through at least one of HTML and XML front 
end. 

11. The method ol , laim 7, wherein the application software's input form is 
transmitted as files to the I Ncr's terminal computer disks. 

12. The method ol v i aim 8, wherein the application software's input form is stored as 
a file on the ASPs service ^ stem's storage disks. 

13. The method <>t claim 3, further comprising, after receiving the billing signal, 
determining whether the I scr has approved the transaction, and inhibiting billing of the 
account associated with thr I : ser f s identity if the User has not approved the transaction. 
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14. The method of claim 13, further comprising, after determining that the User 
approved the transaction, determining whether the application software has successfully 
completed processing of the input information inputted by the User, and inhibiting billing of 
the account associated with the User's identity if the transaction was not completed. 

15. The method of claim 3, further comprising transmitting the cost of the transaction 
billed to the account associated with the User's identity to a billing entity for billing to the 
User in accordance with a billing mechanism established by the User. 

16. The method of claim 12, wherein the billing entity is determined by the billing 
mechanism in accordance with the identity of the User. 

17. The method of claim 12, wherein an Automatic Number Identification (AN1) is 
associated with the User's terminal and a telephone account associated with the ANI is billed 
for the cost of the transaction. 

18. A method of conducting a software usage transaction on a network between a 
User's terminal and a provider for which a charge is determined and billed, comprising: 

receiving from the User's terminal a request for a transaction to use selected 
application software; 

transmitting to the User software input form enabling the User to enter input 
information about the selected application software; 

recei ving from the User the software input form containing the input information data, 
entered by the User, 
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calculating a software usage cost of the transit, on on the basis of the input 
information; 

providing the User with m output form created the application software by 
processing the input information; 

generating a billing signal to bill for the cost of she transaction, the billing signal 
including the cost of the transaction and an assigned irmporary address of the terminal 
requesting the transaction; and 

billing the account associated with the User's identity for the cost of the transaction. 

19. The method of claim 18, wherein the netwoik is one of a data network, the 
Internet, and an Intranet. 

20. The method of claim 18, further comprising, alter receiving the billing signal, 
determining whether the User has approved the transaction, and inhibiting billing of the 
account associated with the User's identity if the User has not approved the transaction. 

21. The method of claim 18, further comprising, alier receiving an approval signal, 
determining whether the selected application software has successfully completed input data 
processing, and inhibiting billing of the account associated with the User's identity if the 
transaction was not completed. 

22. The method of claim 18, further comprising transmitting the cost of the 
transaction billed to the account associated with the User s identity to a billing entity for 
billing to the User in accordance with a billing mechanism established by the User. 
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billing an account associated with the User's identity for the cost of the transaction 



26. A method of billing an account associated with a User's identity for the cost ol ; 
transaction conducted on the Internet between an Internet Service Provider (ISP) and a User * 
terminal through an Internet Access Provider (IAP), the User's terminal being assigned an 
Internet Protocol (IP) address that is used for the transaction, comprising: 

receiving from the User's terminal a request for a transaction to use particuljf 
application software; 

transmitting to the User's terminal screen a software input form enabling the User it. 
enter input information needed to transact the use of said particular application software; 

receiving from the User's terminal the software input form containing the entered 
input information to transact the use of said particular application software; 

. calculating a software usage cost of the transaction in accordance with the entered 
input information; 

providing the User with an output form created by the application software processing 
the entered input information; 

receiving a billing signal to bill for the cost of the transaction, the billing signal 
including the cost of the transaction and an assigned temporary address of the terminal 
requesting the transaction; and 

billing an account associated with the User's identity for the cost of the transaction. 
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